home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2009 February / PCWFEB09.iso / Software / Resources / Chat & Communication / Digsby build 37 / digsby_setup.exe / lib / PIL / ImImagePlugin.pyo (.txt) < prev    next >
Python Compiled Bytecode  |  2008-10-13  |  8KB  |  288 lines

  1. # Source Generated with Decompyle++
  2. # File: in.pyo (Python 2.5)
  3.  
  4. __version__ = '0.7'
  5. import re
  6. import string
  7. import Image
  8. import ImageFile
  9. import ImagePalette
  10. COMMENT = 'Comment'
  11. DATE = 'Date'
  12. EQUIPMENT = 'Digitalization equipment'
  13. FRAMES = 'File size (no of images)'
  14. LUT = 'Lut'
  15. NAME = 'Name'
  16. SCALE = 'Scale (x,y)'
  17. SIZE = 'Image size (x*y)'
  18. MODE = 'Image type'
  19. TAGS = {
  20.     COMMENT: 0,
  21.     DATE: 0,
  22.     EQUIPMENT: 0,
  23.     FRAMES: 0,
  24.     LUT: 0,
  25.     NAME: 0,
  26.     SCALE: 0,
  27.     SIZE: 0,
  28.     MODE: 0 }
  29. OPEN = {
  30.     '0 1 image': ('1', '1'),
  31.     'L 1 image': ('1', '1'),
  32.     'Greyscale image': ('L', 'L'),
  33.     'Grayscale image': ('L', 'L'),
  34.     'RGB image': ('RGB', 'RGB;L'),
  35.     'RLB image': ('RGB', 'RLB'),
  36.     'RYB image': ('RGB', 'RLB'),
  37.     'B1 image': ('1', '1'),
  38.     'B2 image': ('P', 'P;2'),
  39.     'B4 image': ('P', 'P;4'),
  40.     'X 24 image': ('RGB', 'RGB'),
  41.     'L 32 S image': ('I', 'I;32'),
  42.     'L 32 F image': ('F', 'F;32'),
  43.     'RGB3 image': ('RGB', 'RGB;T'),
  44.     'RYB3 image': ('RGB', 'RYB;T'),
  45.     'LA image': ('LA', 'LA;L'),
  46.     'RGBA image': ('RGBA', 'RGBA;L'),
  47.     'RGBX image': ('RGBX', 'RGBX;L'),
  48.     'CMYK image': ('CMYK', 'CMYK;L'),
  49.     'YCC image': ('YCbCr', 'YCbCr;L') }
  50. for i in [
  51.     '8',
  52.     '8S',
  53.     '16',
  54.     '16S',
  55.     '32',
  56.     '32F']:
  57.     OPEN['L %s image' % i] = ('F', 'F;%s' % i)
  58.     OPEN['L*%s image' % i] = ('F', 'F;%s' % i)
  59.  
  60. for i in [
  61.     '16',
  62.     '16B']:
  63.     OPEN['L %s image' % i] = ('I;%s' % i, 'I;%s' % i)
  64.     OPEN['L*%s image' % i] = ('I;%s' % i, 'I;%s' % i)
  65.  
  66. for i in [
  67.     '32S']:
  68.     OPEN['L %s image' % i] = ('I', 'I;%s' % i)
  69.     OPEN['L*%s image' % i] = ('I', 'I;%s' % i)
  70.  
  71. for i in range(2, 33):
  72.     OPEN['L*%s image' % i] = ('F', 'F;%s' % i)
  73.  
  74. split = re.compile('^([A-Za-z][^:]*):[ \\t]*(.*)[ \\t]*$')
  75.  
  76. def number(s):
  77.     
  78.     try:
  79.         return int(s)
  80.     except ValueError:
  81.         return float(s)
  82.  
  83.  
  84.  
  85. class ImImageFile(ImageFile.ImageFile):
  86.     format = 'IM'
  87.     format_description = 'IFUNC Image Memory'
  88.     
  89.     def _open(self):
  90.         if '\n' not in self.fp.read(100):
  91.             raise SyntaxError, 'not an IM file'
  92.         
  93.         self.fp.seek(0)
  94.         n = 0
  95.         self.info[MODE] = 'L'
  96.         self.info[SIZE] = (512, 512)
  97.         self.info[FRAMES] = 1
  98.         self.rawmode = 'L'
  99.         while None:
  100.             s = self.fp.read(1)
  101.             if s == '\r':
  102.                 continue
  103.             
  104.             if not s and s[0] == chr(0) or s[0] == chr(26):
  105.                 break
  106.             
  107.             s = s + self.fp.readline()
  108.             if len(s) > 100:
  109.                 raise SyntaxError, 'not an IM file'
  110.             
  111.             if s[-2:] == '\r\n':
  112.                 s = s[:-2]
  113.             elif s[-1:] == '\n':
  114.                 s = s[:-1]
  115.             
  116.             
  117.             try:
  118.                 m = split.match(s)
  119.             except re.error:
  120.                 v = None
  121.                 raise SyntaxError, 'not an IM file'
  122.  
  123.             if m:
  124.                 (k, v) = m.group(1, 2)
  125.                 if k in [
  126.                     FRAMES,
  127.                     SCALE,
  128.                     SIZE]:
  129.                     v = string.replace(v, '*', ',')
  130.                     v = tuple(map(number, string.split(v, ',')))
  131.                     if len(v) == 1:
  132.                         v = v[0]
  133.                     
  134.                 elif k == MODE and OPEN.has_key(v):
  135.                     (v, self.rawmode) = OPEN[v]
  136.                 
  137.                 if k == COMMENT:
  138.                     if self.info.has_key(k):
  139.                         self.info[k].append(v)
  140.                     else:
  141.                         self.info[k] = [
  142.                             v]
  143.                 else:
  144.                     self.info[k] = v
  145.                 if TAGS.has_key(k):
  146.                     n = n + 1
  147.                 
  148.             raise SyntaxError, 'Syntax error in IM header: ' + s
  149.             continue
  150.             if not n:
  151.                 raise SyntaxError, 'Not an IM file'
  152.             
  153.         self.size = self.info[SIZE]
  154.         self.mode = self.info[MODE]
  155.         while s and s[0] != chr(26):
  156.             s = self.fp.read(1)
  157.         if not s:
  158.             raise SyntaxError, 'File truncated'
  159.         
  160.         if self.info.has_key(LUT):
  161.             palette = self.fp.read(768)
  162.             greyscale = 1
  163.             linear = 1
  164.             for i in range(256):
  165.                 None if palette[i + 256] == palette[i + 256] else palette[i] != chr(i)
  166.                 greyscale = 0
  167.             
  168.             if self.mode == 'L' or self.mode == 'LA':
  169.                 if greyscale:
  170.                     if not linear:
  171.                         self.lut = map(ord, palette[:256])
  172.                     
  173.                 elif self.mode == 'L':
  174.                     self.mode = self.rawmode = 'P'
  175.                 elif self.mode == 'LA':
  176.                     self.mode = self.rawmode = 'PA'
  177.                 
  178.                 self.palette = ImagePalette.raw('RGB;L', palette)
  179.             elif self.mode == 'RGB':
  180.                 if not greyscale or not linear:
  181.                     self.lut = map(ord, palette)
  182.                 
  183.             
  184.         
  185.         self.frame = 0
  186.         self._ImImageFile__offset = offs = self.fp.tell()
  187.         self._ImImageFile__fp = self.fp
  188.         if self.rawmode[:2] == 'F;':
  189.             
  190.             try:
  191.                 bits = int(self.rawmode[2:])
  192.                 if bits not in (8, 16, 32):
  193.                     self.tile = [
  194.                         ('bit', (0, 0) + self.size, offs, (bits, 8, 3, 0, -1))]
  195.                     return None
  196.             except ValueError:
  197.                 pass
  198.             except:
  199.                 None<EXCEPTION MATCH>ValueError
  200.             
  201.  
  202.         None<EXCEPTION MATCH>ValueError
  203.         if self.rawmode in ('RGB;T', 'RYB;T'):
  204.             size = self.size[0] * self.size[1]
  205.             self.tile = [
  206.                 ('raw', (0, 0) + self.size, offs, ('G', 0, -1)),
  207.                 ('raw', (0, 0) + self.size, offs + size, ('R', 0, -1)),
  208.                 ('raw', (0, 0) + self.size, offs + 2 * size, ('B', 0, -1))]
  209.         else:
  210.             self.tile = [
  211.                 ('raw', (0, 0) + self.size, offs, (self.rawmode, 0, -1))]
  212.  
  213.     
  214.     def seek(self, frame):
  215.         if frame < 0 or frame >= self.info[FRAMES]:
  216.             raise EOFError, 'seek outside sequence'
  217.         
  218.         if self.frame == frame:
  219.             return None
  220.         
  221.         self.frame = frame
  222.         if self.mode == '1':
  223.             bits = 1
  224.         else:
  225.             bits = 8 * len(self.mode)
  226.         size = ((self.size[0] * bits + 7) / 8) * self.size[1]
  227.         offs = self._ImImageFile__offset + frame * size
  228.         self.fp = self._ImImageFile__fp
  229.         self.tile = [
  230.             ('raw', (0, 0) + self.size, offs, (self.rawmode, 0, -1))]
  231.  
  232.     
  233.     def tell(self):
  234.         return self.frame
  235.  
  236.  
  237. SAVE = {
  238.     '1': ('0 1', '1'),
  239.     'L': ('Greyscale', 'L'),
  240.     'LA': ('LA', 'LA;L'),
  241.     'P': ('Greyscale', 'P'),
  242.     'PA': ('LA', 'PA;L'),
  243.     'I': ('L 32S', 'I;32S'),
  244.     'I;16': ('L 16', 'I;16'),
  245.     'I;16B': ('L 16B', 'I;16B'),
  246.     'F': ('L 32F', 'F;32F'),
  247.     'RGB': ('RGB', 'RGB;L'),
  248.     'RGBA': ('RGBA', 'RGBA;L'),
  249.     'RGBX': ('RGBX', 'RGBX;L'),
  250.     'CMYK': ('CMYK', 'CMYK;L'),
  251.     'YCbCr': ('YCC', 'YCbCr;L') }
  252.  
  253. def _save(im, fp, filename, check = 0):
  254.     
  255.     try:
  256.         (type, rawmode) = SAVE[im.mode]
  257.     except KeyError:
  258.         raise ValueError, 'Cannot save %s images as IM' % im.mode
  259.  
  260.     
  261.     try:
  262.         frames = im.encoderinfo['frames']
  263.     except KeyError:
  264.         frames = 1
  265.  
  266.     if check:
  267.         return check
  268.     
  269.     fp.write('Image type: %s image\r\n' % type)
  270.     if filename:
  271.         fp.write('Name: %s\r\n' % filename)
  272.     
  273.     fp.write('Image size (x*y): %d*%d\r\n' % im.size)
  274.     fp.write('File size (no of images): %d\r\n' % frames)
  275.     if im.mode == 'P':
  276.         fp.write('Lut: 1\r\n')
  277.     
  278.     fp.write('\x00' * (511 - fp.tell()) + '\x1a')
  279.     if im.mode == 'P':
  280.         fp.write(im.im.getpalette('RGB', 'RGB;L'))
  281.     
  282.     ImageFile._save(im, fp, [
  283.         ('raw', (0, 0) + im.size, 0, (rawmode, 0, -1))])
  284.  
  285. Image.register_open('IM', ImImageFile)
  286. Image.register_save('IM', _save)
  287. Image.register_extension('IM', '.im')
  288.